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The Burroughs B 2500, B 3500, and B 2700 
memories and central processors offer a totally 
integrated design that incorporates monolitic, 
solid-state circuitry. 


CORE MEMORY 


The core memory, being extremely modular, 
allows for configurations that easily provide for 
most user requirements. Base and limit registers 
are designed within the memory logic to allow 
the system to utilize dynamic storage allocation 
and, perhaps of greatest importance, is that all 
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INTRODUCTION 


memory addresses are digit addressable and the 
memory itself is easily incrementable. 


CENTRAL PROCESSOR 


The central processor contains the circuitry to 
perform the instruction set. The instructions 
are capable of performing operations on digit, 
byte, or word formatted fields. The internal 8- 
bit code may be either EBCDIC or USASCII 
code and is programmatically selectable. In ad- 
dition to executing the instruction set, the proc- 
essor has an automatic interrupt system. 
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SECTION 1 
CORE MEMORY 


GENERAL 60,000 characters. Figure 1-2 shows a layout di- 

sake as rae agram of the Central Control and Memory Base 
The main memory utilized is a four-wire coinci- A cabinet, and figure 1-3 shows the internal 
dent current core memory with a minimum cy- hardware of the cabinet. 


cle time of one microsecond. Depending on the 
system storage, memory is variable in size from 
10,000 characters up to a maximum of 500,000 
characters. 


A typical memory cabinet is shown in figure 1- 
1. Two types of core memory cabinets are avail- 
able: Central Control and Memory Base A 
cabinet and the Memory Base B cabinet. 


Figure 1-4 is a block diagram of the entire 
memory system. 


Individual core modules, referred to as stacks, 
are available in 10,000 (10K) character, 20K 
character, and 30K character sizes. Each of 
these stacks is completely independent, contain- 
ing all necessary drivers, sense amplifiers, and 
core. 


CENTRAL CONTROL AND MEMORY BASE A 
CABINET 


The Central Control and Memory Base A 
cabinet is used in the Two Cabinet System. 
Within this cabinet there is space allocated for 
up to two memory stacks and since the largest 
stack contains 30,000 characters, the Two 
Cabinet System is limited in core storage to 
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Figure 1-2. Central Control and Memory Base A Cabinet Layout 
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Figure 1-3. Central Control and Memory Base A 
Cabinet 


MEMORY BASE B CABINET 


The Memory Base B cabinet houses up to five 
memory stacks and provides these systems 
with measurably more storage. Figure 1-5 is a 
layout diagram of the Memory Base B cabinet 
and figure 1-6 shows the internal hardware of 
the cabinet. — 


Certain Models of the B 2500 and B 2700 are 
configured into three cabinet systems (CPU, 
Peripheral Controls, and Memory Base). These 
Systems operate with one Memory Base B 
cabinet, with a maximum core storage of 120K 
characters (four 30K stacks). 


Additional models of the B 2700 and B 3500 
Systems can each utilize up to four Memory 
Base B cabinets. The first three cabinets, each 
containing five 380K stacks, provide these sys- 
tems with storage for up to 450K characters. 
The fourth cabinet can house only up to 50K 
characters, giving the system a total memory 
storage capacity of 500K characters. The 
memory stacks are placed in specific locations 
within the cabinet as shown in the layout 


diagram, figure 1-5. Each consecutive stack 
area must contain a full 30K characters before 
the next location can be utilized. 


MEMORY STACKS 


Figure 1-7 is a detailed block diagram of a core 
memory stack with associated control circuits. 
Each stack is self-sufficient in that it contains 
all necessary timing circuits, drivers, and sense 
amplifiers to be totally independent of all other 
stacks. However, if the storage size of the core 
memory is changed, the memory-size card, lo- 
cated in the central processor, must be changed. 


Stack Configuration 


Each core stack is 17 planes deep (figure 1-8), 
with each word containing one bit from each 
plane. This results in a 16-bit (four digit) word 
with one parity bit. 


Each plane has its own sense and inhibits lines. 
They share addressing lines for associated loca- 
tions on the other planes. 


Array positioning provides for coordinate ad- 
dressing of the desired core position. Figure 1- 
9 is a block diagram showing the three types 
of arrays: the 50 x 100 array for the 10,000 
character stack, the 100 x 100 array for the 
20,000 character stack, and the 100 x 150 array 
for the 30,000 character stack. 


For addressing purposes, each stack is divided 
into 5,000 character sections referred to as 
sextants. The 30,000 character stack (figure 1- 
9) contains six sextants, the 20,000 character 
stack contains four sextants, and the 10,000 
character stack contains two sextants. 


MEMORY CONTROL 


The interface between memory control, central 
processor and central control is shown in figure 
1-10. Figure 1-11 is a detailed block diagram of 
the memory control logic and the interfacing of 
this logic to the memory stacks. 


The memory cycie begins when either the cen- 
tral processor or an I/O channel request is 
granted access to memory. When the access is 
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Figure 1-4. Memory Block Diagram 
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Figure 1-5. Memory Base B Cabinet Layout 


Figure 1-6. Memory Base B Cabinet 


1-4 


granted, a series of address decoding proce- 
dures are initiated. This addressing is_ per- 
formed in the following sequence: 


a. Cabinet addressing. 


b. Stack addressing. 


ce. Sextant addressing. 


d. Location. 


Figure 1-12 shows an exploded view of the com- 
plete memory scheme. The first breakdown is 
from the address in the address register (ADR), 
located within the central processor, into 
cabinet selection. Once the cabinet is located, 
the stack within the cabinet is determined from 
the address in the memory address register 
(MAR). Next, the proper sextant is selected 
and, with the last four digits in the MAR, two 
transformers lines are selected: one “X” and one 
wy 


Cabinet Addressing 


Cabinet addressing is determined by the decod- 
ing of the most significant digit (MSD) of the 
address within the address register of the proc- 
essor (ADR) when a memory access has been 
granted. As the access is granted to either an 
I/O channel or the central processor, a term 
called memory start (MST) is gated with the 
MSD in the ADR, which then sends the start 
level to the proper cabinet. 


Stack Addressing 


Stack addressing is accomplished by gating dig- 
its 5 and 6 of the memory address register with 
the start stack timing level (SSTL). Since a stack 
can contain up to 60,000 digits, stack number one 
is selected when the MAR is from 000,000 up to 
059,999; stack number two is selected when the 
MAR is from 060,000 up to 119,999, etc. The 
MAR values and address of stacks are as follows: 


Value of MAR Addressed Stack 
000,000 - 059,999 1 
060,000 - 119,999 2 
120,000 - 179,999 3 
180,000 - 239,999 4 
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240,000 - 299,999 
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Figure 1-7. Stack Block Diagram 


Sextant Addressing 


As previously mentioned, a sextant is a 5,000 
character section of a stack with six sextants 
in a 30,000 character stack, four sextants ina 
20,000 character stack, and two sextants in a 
10,000 character stack. The sextants are desig- 
nated 1 through 6, depending on the stack size, 
as shown in figure 1-9. Since each of the five 
stacks have sextants 1 through 6, there are five 
groups of stack addresses which could select 
each sextant term. The proper sextant is deter- 
mined by digits 5 and 6 of the memory address 
register. 


1-5 


Sextant one is selected by the term sextant 1 
(SX1). This term is used to select the group of 
transformers that drives current through the 
selected sextant. Sextants 2 through 6 are 
selected in a similar manner by terms SX2 
through SX6. 


Location 


As shown in figure 1-9, a full stack contains six 
sextants, with each sextant occupying a specific 
location within the stack. The stack is ad- 
dressed by 150 “X” address lines and 100 “Y” 
address lines with each sextant having 50 
intersecting “X” and “Y” lines. 
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Figure 1-8. Memory Planes 


Each of these addressing lines is connected to 
the secondary of a transformer with a single 
transformer for each line. The selection of one 
“X” transformer and one “Y” transformer com- 
pletes the coordinate addressing of a specific lo- 
cation. 


The selection of the proper transformer is ac- 
complished with the last four digits of the MAR 
and the sextant decoding described earlier. The 
sextant information divides the transformers 
into groups of 50. However, the “X” address line 
that intersects sextant 1 (SX1) also passes 
through SX3, as shown in figure 1-9. Similarly, 
the “X” address lines that intersect sextants 2 
and 3 also pass through sextants 4 and 6, re- 
spectively. The “Y” address that intersects 
sextants 1 and 8 also passes through sextants 
2 and 5, and 4 and 6, respectively. 


Figure 1-13 shows that if the address in the 
MAR selects SX1, only the group of transfor- 
mers whose output lines pass through SX1 and 
SX3 for the “X” transformer matrix and 
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through SX1, SX2 and SX5 for the “Y” trans- 
former matrix are enabled. However, only SX1 
experiences coordinate intersection, which 
means that only sextant 1 is provided with both 
“X” and “Y” half-current. 


The summation of these two half-currents 
provides full current (2 times one-half), which 
is required to fully change the state of the core. 
The other sextants included with the transfor- 
mers that intersect SX1 only receive half of the 
required current, either from the “X” or “Y” 
transformer matrix. 


The transformers are selected by the 
intersection of two address decoding lines. The 
“X” address lines are decoded from _ sextant 
MAR thousands and MAR units gating, where- 
as the “Y” address lines are decoded from the 
sextant, MAR hundreds, and MAR tens. Refer 
to figure 1-14. One group of address decoding 
lines is composed of the thousands position, dig- 
it 4 of MAR. Since digit 4 can contain ten dif- 
ferent configurations (0 through 9), it is de- 
coded into ten different address decoding lines 
directly from the binary count in the MAR digit 
4 position. These lines are designated KO, K1, 
K2 through K9. 


The other group of 15 lines is composed of the 
unit sextant gating. The “X” transformers must 
address through different pairs of sextants. 


These five unit terms U0 through U5, combined 
with the three sextant terms, gates the group 
of 15 lines to the transformer matrix. A com- 
plete block diagram of these lines and associ- 
ated gating is shown in figure 1-15. At the point 
of intersection of the decoding lines, a transfor- 
mer is selected. Only one horizontal line and 
one vertical line can be enabled during a 
memory access; therefore, only one transformer 
is enabled. This drives current through one “X” 
address line of the core stack. 


The selection of the “Y” transformer is accom- 
plished in the same identical manner as the 
selection of the “X” transformer. The “Y” trans- 
formers are arranged in a 10 x 10 array, as 
shown in figure 1-16. This array is addressed by 
two groups of ten lines. One group of ten lines is 
decoded from the hundreds position (digit 3 of 
the MAR), while the other group of ten lines is 
decoded from the even tens position (digit 2 of 
the MAR) and the sextant gating. 


"Vv" TRANSFORMER “Y" TRANSFORMER “Y¥" TRANSFORMER 
MATRIX MATRIX MATRIX 


fANyet uve 
50 50 50 50 50 
ADDRESS ADDRESS 
LINES LINES LINES LINES LINES LINES 


x 


SEXTANT] SEXTANT 


SEXTANT | SEXTANT 
SEXTANT | SEXTANT 
Fake 
SEXTANT | SEXTANT 

| a 


100 BY 150 ARRAY 


mpmZ2zpvom“2yrD 
pmZzmvom%"2>TDH 


50 BY 100 ARRAY 


mmeDonnon2z2rgwaa 


x-DoAPEe 


x-DiAPES 


100 BY 100 ARRAY 


Figure 1-9. Address Lines Through Sextants 


The tens and units positions of MAR can de- The hundreds lines are decoded from the binary 
scribe 100 different digit addresses. There are count in the hundreds position of the MAR. 
five word addresses in each 20 consecutive digit This count can be from 0 through 9, with each 
addresses starting with 000,000. count being designated HO through H9. 

The first word of each 20 addresses contains an The output of the “Y” transformers passes 
even digit (MAR tens equal to 0, 2, 4, 6 and 8). through two groups of three sextants, as shown 


The odd MAR digits have a value of 0 through in figure 1-9. These groups form the terms SX1, 
3 for any digit address in the first word. The SX2, or SX5 and SX8, SX4, or SX6, with each 


address of any digit in the first word is desig- gate having five even tens terms to achieve the 
nated by the term UO. ten gating lines to the matrix. The even tens 

terms are decoded directly from the ten posi- 
The second word of each 20 addresses contains tions of MAR minus the one bit used in the 
an even (MAR 2, and MAR 1) digit value of 4 units gating. The terms TO, T2, T4, T6 and T8 
through 7. The term for this decoding is U1. are derived from this count. Refer to figure 1- 


9. Addressing is now complete. (The transfor- 
mers drive the address lines which select one 


The three remaining unit terms (2 through 5) specific location which contains one word or 
are decoded in the same manner, generating the four digits, plus a parity bit. Examples of ad- 
terms U2 through U4. dress breakdown are given in table 1-1. 
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Figure 1-10. Memory Control Interface 


Table 1-1. Examples of Address Breakdown 


Address | Cabinet | Address 
in ADR |Location|in MAR | Location | Location Digit 2 | Term 


183620 183620 
382195 082195 


491835 | 191835 


604171 004171 
895952 295952 


962111 062111 
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Figure 1-11. Memory Control/Stack Interface 
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Figure 1-13. Sextant Gating of Transformers 
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Figure 1-14. 15 x 10 ‘'X”’ Transfer Array 


PARITY 


The memory system operates with odd parity. 
This stipulates that an odd number of bits is set 
for each word location. That is, if a word is 
placed in the memory information register 
(MIR), which contains an even number of bits 
set, the parity bit must also be set at the time 
the word is written. If the word within the MIR 
contains an odd number of bits, the parity bit 
need not be utilized. 


MEMORY TIMING 


The memory cycle is one microsecond in dura- 
tion. Logic generated within the central control, 
and which is then called to memory, synchro- 
nizes timing pulses between memory, the cen- 
tral control, and the central processor. The time 
duration between clock pulses is 560 
nanoseconds. 


Memory timing is generated in both memory 
control and the stack. When a memory cycle is 
required by the central processor or an I/O 
channel, the central processor triggers the tim- 
ing circuits located within memory control. The 
appropriate stack is selected by address decod- 
ing and its timing circuits enabled by a Start 


Stack Level (SnSL). This logic produces timing 
pulses required to control the stack function. 


STACK TIMING 


The timing generated by the stack timing logic 
is used to control the sequence of operations 
that causes read and write current to flow with- 
in the stack. 


READ OPERATION 


The address to be used during the read 
operation is received from the address register 
within the central processor and is stored in the 
memory address register (MAR). The MAR is 
decoded by the stack decoding logic and gated 
to produce one of five SnSL levels. This level, 
in turn, determines the stack to be used. The 
MAR 1s also utilized by the address and sextant 
decoding logic to determine the location within 
the stack that is to be utilized. This information 
is gated to all stacks within the memory 
cabinet, but it is usable only in the stack receiv- 
ing the SnSL level. After the stack is triggered 
by SnSL, the output from the sense amplifiers 
is sent to the memory information register 
(MIR). The sense amplifier senses the status of 
the cores within the stack. The type of 
operation to be performed is stored in the mem- 
ory control latches (MCL), which is then de- 
-oded and controls the input to the MIR. In the 
case of a read operation, the outputs from the 
sense amplifiers are gated to the MIR where 
they are then sent to the central control or cen- 
tral processor for usage. 


WRITE OPERATION 


For a write operation, the logic utilized for the 
read operation is valid, except that the MCL 
now contains codes for a write operation. The 
outputs of the sense amplifiers are inhibited 
and only the new information from the central 
control or central processor is latched in the 
MIR. The inhibit gating, in turn, controls the 
writing of the information within the MIR into 
a memory location addressed by the MAR. 
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Figure 1-15. ‘‘X’’ Transformer Decoding Lines 
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GENERAL 


The Central Processors contain the circuitry 
and logic required to perform the instruction 
set utilized by their associated systems. These 
instruction sets are capable of performing oper- 
ations on digit-, byte-, or word-formatted data 
fields. The internal working code utilized by the 
central processors is 8-bit EBCDIC or 8-bit 
USASCII, both of which are programmatically 
selectable. Integrated into the hardware is an 
automatic interrupt system capable of 
informing the processor of any condition experi- 
enced by any portion of the system. 


The B 2500/B 3500 and the B 2700 Central Proc- 
essor speeds are as follows: 


Processor 
Model Speed 
B 2510/B 2520 0.5 MHz 
B 2731 0.67 MHz 
B 2501/B 2502/B 2741/B 2761/ 1.0 MHz 
B 2540/B 2765 
B 2751/B 2771/B 2772/B 3501/ 2.0 MHz 


B 3506/B 3508/B 3510/B 3514 


PROCESSOR OPERATING MODES 


The Central Processors can operate in one of 
four modes: control state, zero base; control 
state, non-zero base; normal state, zero base; 
and normal state, non-zero base. 


Control State, Zero Base 


In this mode, the interrupt flip-flop can be set, 
but the interrupt branch is not executed until 
the return to normal state. Any privileged in- 
structions are allowed. 


Contro! State, Non-Zero Base 


In this mode, the interrupt flip-flop can be set, 
but the interrupt branch is not executed until 
the return to normal state. Any privileged in- 
structions are disallowed. 
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SECTION 2 
CENTRAL PROCESSOR 


Normal State, Zero Base 


In this mode, the interrupt branch is allowed 
to be executed and privileged instructions are 
allowed. 


Normal State, Non-Zero Base 


In this mode, the interrupt branch is allowed 
to be executed and privileged instructions are 
disallowed. 


Object program, assemblers, compilers, and 
generators are executed in the normal state, 
non-zero base, whereas the greater majority of 
the Master Control Program (MCP) is executed 
in the control state, zero base. A small number 
of privileged instructions, used exclusively by- 
the MCP, can be executed only in zero base. 
These priviledged instructions include opera- 
tions such as initiate output and read timer. 


LOGICAL UNITS 


There are several logical units contained within 
the central processor that directly or indirectly 
affect its operation. These logical units control 
the execution of specific instructions and are, 
themselves, set or changed by other  instruc- 
tions. 


OVERFLOW Flip-Flop 


The OVERFLOW flip-flop is a hardware logical 
unit that indicates the data field of a move or 
arithmetic instruction is exceeded. If an over- 
flow condition is detected, the command is 
executed but the data is not affected. The 
OVERFLOW flip-flop is not cleared at the be- 
ginning of an arithmetic operation but is pre- 
served; therefore, it indicates overflow that has 
occurred any time before or during a series of 
arithmetic operations or other interjected non- 
arithmetic operations. Instructions that can 
create an overflow condition are: 


a. Arithmetic instructions except multiply. 
b. Floating point arithmetic instructions. 
c. Move Numeric. 


d. Move Alphanumeric. 
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Overflow cannot occur during a multiply in- 
struction, since the receiving field is always 
large enough to contain the product. In all cases 
except the floating point instructions, overflow 
results when the receiving field cannot contain 
the sending field. With floating point instruc- 
tions, the overflow can also be caused by an 
out-of-range exponent. The OVERFLOW flip- 
flop is reset by the Branch-On-Overflow  in- 
struction. Once cleared, it can be set if the con- 
ditions arise while executing those instructions 
that may cause it to be set. There are two ways 
in which the present setting of the OVERFLOW 
flip-flop may be stored in the four-bits of re- 
served address memory and then cleared, as 
shown below. 


a. Branch Communicate. 
b. Automatic interrupt feature. 


The OVERFLOW flip-flop is restored from the 
reserved memory location by the Branch 
Reinstate instruction. In addition, the object 
program may branch to some subroutine and 
the OVERFLOW flip-flop setting must be re- 
tained and restored at the conclusion of the sub- 
routine execution, prior to continuing in the ob- 
ject program. The Enter instruction stores the 
flip-flop setting into the four bits of the re- 
served character location in the memory stack, 
and then clears the OVERFLOW flip-flop. The 
Exit instruction restores the OVERFLOW flip- 
flop setting from this reserved location. 


COMPARISON Flip-Flops 


Two hardware flip-flops make up the 
comparison logical unit. These two flip-flops 
have the following four combinations (0 = 
reset, 1 = set): 


a. 00 — cleared. 

b. 01 — greater or high comparison result. 

c. 10 — less or low comparison result. 

d. 11 — zero or equal comparison result. 
These four states represent the result of execu- 
ting an instruction that affects these logical 
units. The cleared state actually indicates that 


there is no comparison result existing. The in- 
structions that set a result into the 
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COMPARISON flip-flops and are reflected on 
the appropriate console indicators are as fol- 
lows: 


a. All arithmetic instructions. 

b. All floating point instructions. 
c. Compare instructions. 

d. Move Numeric instruction. 

e. Move Alphanumeric instruction. 
f. The bit test instruction. 

g. The logical instructions. 

h. The scan instructions. 

i. The Edit instruction. 

j. The Scan Result Descriptor instruction. 
k. Search instruction. 


Any branching that is done on the basis of the 
comparison will not change the status of the 
flip-flops. Only another instruction that affects 
them can change their status. When entering 
control state by means of the Branch Communi- 
cate instruction or the automatic interrupt sys- 
tem, the status of the comparison flip-flops is 
stored. The 2-bit and 1-bit of the same charac- 
ter that stores the OVERFLOW flip-flop status 
will contain the status of the COMPARISON 
flip-flops. The flip-flops are then cleared before 
branching to control state. When return is 
made to the normal state, the Branch Reinstate 
instruction will restore the comparison flip- 
flops from the character in reserved address 
memory. Similarly, when entering a_ subrou- 
tine, the Enter instruction stores the COMPAR- 
ISON flip-flops in the 2-bit and 1-bit of the 
specified character in the memory stack. This 
same character contains the OVERFLOW flip- 
flops status. When leaving the subroutine with 
the Exit instruction, the COMPARISON flip- 
flops are restored from this character in the 
stack. 


EBCDIC/USASCII Mode Flip-Flop 


This flip-flop determines whether the processor 
is operating on EBCDIC or USASCII internally 
coded data. The reset state of the flip-flop indi- 


cates that the processor is using the EBCDIC 
code. The flip-flop can be programmatically set 
to indicate that the processor is to use USASCII 
code. The Set Mode instruction sets or resets 
this flip-flop, as desired by the programmer. 
The following instructions are sensitive to the 
setting of the EBCDIC/USASCII mode flip- 
flop: 


a. All Arithmetic instructions. 


b. All Floating Point instructions. 


c. Move Numeric instruction. 


d. 


Move Alphanumeric instruction. 
e. Move Repeat instruction. 
f. Translate instruction. 


g. Sean Delimiter Equal instruction. 


h. Scan Delimiter Unequal instruction. 


i. Edit instruction. 


When branching to the control state, the setting 
of the EBCDIC/USASCII MODE flip-flop is al- 
so stored in the 8-bit of the same character con- 
taining the settings of the OVERFLOW and 
COMPARISON flip-flops. It is then cleared pri- 
or to entering the control state. This is done by 
either of the following instructions: 


a. Branch Communicate. 
b. Automatic interrupt branch. 


When returning to normal state, the Branch 
Reinstate instruction will restore the EBCDIC/ 
USASCII mode flip-flop from the character in 
reserved address memory. When entering a 
subroutine, the Enter instruction will store the 
status of the MODE flip-flop in the 8-bit of the 
specific character in the stack which also con- 
tains the OVERFLOW and COMPARISON flip- 
flop settings. The Exit instruction will restore 
the EBCDIC/USASCII MODE flip-flop from 
the character in the stack when leaving the sub- 
routine. This is necessary in the event that the 
flip-flop is changed by the subroutine. The spe- 
cial character in reserved memory or the stack 
contains the setting of the EBCDIC/USASCII 
mode flip-flop in the 8-bit, the setting of the 
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OVERFLOW flip-flop in the 4-bit, and the set- 
tings of the COMPARISON flip-flops in the 2- 
bit and 1-bit. 


INTERRUPT Flip-Flop 


The INTERRUPT flip-flop is a hardware logical 
unit that indicates the presence of an interrupt. 
This flip-flop controls the automatic interrupt 
circuitry when the processor is operating in 
normal state. If the flip-flop is reset (no inter- 
rupt condition), execution continues in sequence 
from instruction to instruction. If an interrupt 
occurs, the flip-flop is set. If the flip-flop is set 
at the completion of an instruction execution 
cycle, the automatic interrupt branch to control 
state, base zero occurs. The flip-flop is set by 
the detection of any I/O complete interrupt. 
The Sean Result Descriptor instruction will re- 
set the INTERRUPT flip-flop while executing 
the interrupt handling routine. 


Normal/Control State Flip-Flop 


This flip-flop can be set only by the Branch 
Reinstate instruction which is executed by the 
Operating System. It is reset by either the 
Branch Communicate instruction or the auto- 
matic interrupt branch. When the flip-flop is 
set, the processor is operating in the control 
state which inhibits the automatic interrupt cir- 
cuiltry. 


The setting of this flip-flop dictates the state of 
operation of the processor. When it is set, the 
processor is operating in normal state and al- 
lows the execution of the automatic interrupt 
branching. 


Timer 


The timer consists of two words in address 
memory. The first timer word is counted at a 
one KiloHertz rate. This word is compared with 
the value of the second word which is placed 
there by the Operating System. When the first 
word is equal to or greater than the second 
word, a clock interrupt occurs. The timer will 
continue to count after the interrupt and re- 
quires the Operating System to read and clear 
the first word of the timer. The value read from 
the timer word is used by the Operating System 
for logging functions and updating the real- 
time clock. 
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Base Register 


The base register in the processor is a three-dig- 
it register. These three digits are always added 
to the two high-order digits of the five-digit 
program and instruction address to form a six- 
digit absolute address. This makes the base reg- 
ister modulo 1000, that is, a base register value 
of 187 is actually 137,000. This base register val- 
ue is always added to the base relative address 
contained in the instructions. This computation 
takes place during the fetch cycle, prior to stor- 
ing the absolute address generated into address 
memory. For any program, the base register 
value is created by the Operating System and 
stored in reserved memory location 000070 (ta- 
ble 2-1) prior to initiating the program. When 
the Branch Reinstate instruction is executed, 
the base register is set to the value contained 
in reserved memory, establishing the base reg- 
ister of the normal state program. If a Branch 
Communicate instruction or an automatic inter- 
rupt branch is executed, the base register value 
is stored in the reserved address memory loca- 
tion prior to entering control state and the base 
register is also cleared to zero. 


Limit Register 


The limit register within the processor is a 
three-digit register. The purpose of the limit 
register is to provide memory protection. Mem- 
ory protection is accomplished by comparing 
the high-order three digits of the absolute ad- 
dress generated for instructions with the base 
and limit registers. The base register provides 
the lower limit and the limit register provides 
the upper limit. The value of the limit register 
is provided by the Operating System and stored 
in reserved memory location 000073. The 
Branch Reinstate instruction sets the limit reg- 
ister to the value contained in reserved 
memory. When the Branch Communicate in- 
struction or automatic interrupt branch is 
executed, the limit register value is stored in re- 
served memory prior to entering control state 
and the limit register is set to the system mem- 
ory size. This allows the Operating System to 
access all memory. 


Index Registers 
The index registers used in the processors are 


not hardware registers as are the base and limit 
registers. Three index registers are contained in 


reserved locations of an object program and are 
always assigned the same base relative address. 
The format of the index register is shown in fig- 
ure 2-1. 


8 8 
4 
1 1 


ea 
“0 


i Ye 
SIGN INDEX VALUE 


Figure 2-1. Index Register Format 


Each index register consists of eight digit posi- 
tions. The most significant digit (D1) is the sign 
of the index value. The second digit position is 
not used when indexing. The value of the index 
is the decimal value contained in the remaining 
six digit positions (D3 through D8). If an in- 
struction address specifies indexing, the value 
of the specified index register is added 
algebraically to the base register, plus the base 
relative address prior to storing the generated 
address in address memory. The index register 
value can be changed by any instruction that 
addresses memory. In addition, the Enter and 
Exit instructions use and alter the setting of In- 
dex Register 3 (IX3); however, the settings are 
saved and restored. In the zero-base state, the 
Sean Result Descriptor instruction and _ the 
Search instruction use [X1 in their execution. 


DATA MODES 


Two data modes are utilized in the Processors to 
represent internal data: the 4-bit mode and the 
8-bit mode. 


Four-Bit Mode 


In the 4-bit mode, data is interpreted in units 
of 4-bits and, where a sign is expected, the sign 
is interpreted as a separate and leading 4-bit 
unit. The internal code in 4-bit mode is inter- 
preted by the arithmetic unit in the processor 
as follows: 


Binary Decimal 
_Code_ Sign Code Equivalent 
0000 + 0 

0001 + 1 

0010 sf 2 

0011 =F 3 

0100 + 4 

0101 ze 5 

0110 + 6 

0111 3 7 

1000 + 8 

1001 + 9 

1010 + A (undigit 0) * 
1011 + x (undigit 1) « 
1100 + 2 (undigit 2) « 
1101 - 4% (undigit 3) * 
1110 + A (undigit 4) * 
1111 “p 4 (undigit 5) * 


* These units are 
accepted by the 
arithmetic unit but 
they will result in 
unspecified results. 


When a signal 4-bit format is specified in the 
receiving field for any operation, a plus sign 
compares higher than a minus sign in the sys- 
tem’s collating sequence, as shown below: 
USASCII Code EBCDIC Code 
+ = 1011 + =1100 
= 1101 - =1101 


Eight-Bit Mode 


In an 8-bit mode, data is interpreted in units 
of 8-bits (one byte). Any required conversion be- 
tween 4-bit and 8-bit mode is accomplished au- 
tomatically during the execution of instructions 
with no timing costs absorbed by the program 
being operated. 
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For code sensitive instructions including the 
manipulation of 4-bit numeric data, the most 
significant fours bits of a 2-byte receiving field 
are automatically set to the code indicating the 
numeric subset of the selected 8-bit code. The 
four bits are 1111 (undigit 5) in EBCDIC code 
and 0101 (binary 5) is USASCII code. 


Except in the move alphanumeric, move numer- 
ic and edit instructions, 8-bit data is considered 
unsigned. 


Alphanumeric comparisons are performed in bi- 
nary code. The collating sequence for EBCDIC 
code is special characters, alphabetical charac- 
ters, and then digits. The collating sequence for 
USASCII is special characters, digits, and then 
alphabetical characters. 


INSTRUCTION FORMAT 


The two instruction formats used by the proces- 
sors are format A, which is variable in length 
from one to four syllables, or format B, which 
is a fixed length of eight digits. Most instruc- 
tions consist of from one to four syllables, de- 
pending on the particular instruction. An in- 
struction syllable consists of six digits as shown 
in figure 2-2. 


The first syllable of every instruction contains 
the operation code in digits D1 and D2. Digit 
positions D3 through D6 have various functions 
as specified by each instruction. Generally, D3 
and D4 specify the length of the A field, where- 
as D5 and D6 specify the length of the B field. 
Several instructions consist of a single syllable. 
In multiple syllable instructions, the second, 
third, and fourth syllables are the A field, B 
field, and C field addresses, respectively. The 
addresses always address the most significant 
digit of the field. Digits D7, D138, and D19 
specify various control functions with respect to 
the A, B, and C field addresses, respectively. 
The two address-index bits determine which in- 
dex register, if specified, to use in generating 
the absolute address. The two address-control- 
ler bits specify whether signed or unsigned 4- 
bit or 8-bit formatted information is in the data 
field. The address controller bits may also spec- 
ify indirect addressing. Digits D3 and D4 of the 
first syllable can specify that the second sylla- 
ble (D7 through D12) is a literal value and not 
an address. The format of the literal is given 
in digits D3 and D4. 
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SYLLABLE 1 © 


OPERATOR 
CODE 


AS SPECIFIED 
BY INSTRUCTION 


SYLLABLE 3 


i HAAR RRA NAA 
BINARY ( 


421 8421 8 


VALUES ry 184 


B ADDRESS 


AARARARARARANARARARRRA I 


8421 8421'8421 84218421 8421 8421 842] 8421 8421 8421 842] 
NS a ee ey 


L A ADDRESS | 


SYLLABLE 2 


Rn 


BINARY 
VALUES 


A ADDRESS 
CONTROLLER 


A ADDRESS 


INDEX SYLLABLE 4 


18421 8421 8421 8421 8421 


CONTROLLER Sree 


C ADDRESS 


Ts sooness 


INDEX 


INDEX 


Figure 2-2. Six-Digit Instruction Format 


The 8-digit format is used only when an 
operation code and address are necessary, such 
as in a Branch instruction. The 8-digit instruc- 
tion format is shown in figure 2-3. — 


Address Index 


The two most significant bits (8 and 4) of the 
first digit in the address field is the address in- 
dex control. The bit configuration of the address 


index signifies which of three index registers is 
to be used while generating an absolute address. 
The eight-bit and four-bit configuration is as 
follows: 

a. 00 — no indexing. 


b. 01 — index register 1 (IX1). 
c. 10 — index register 2 (IX2). 
d. 11 — index register 3 (IX3). 


RWRARHRARARG | 


‘8421 aie aa ied 8421 8421 8421 8421 8421 BINARY VALUES 


[ADDRESS OR 
omens CONTROLLER 
CODE ADDRESS 
INDEX 


ADDRESS 


Figure 2-3. Eight-Digit Instruction Format 


There is an address index controller for the A, 
B, and C address fields, and also for the address 
field of the eight-digit instruction. If indexing 
is specified, the designated index register value 
contained in reserved locations within an object 
program is added algebraically to the address 
field and base register during the fetch cycle, 
prior to storage in its reserved address memory 
location. 


Address Controller 


The two low-order bits (2 and 1) of the first dig- 
it in the address field specify the data field for- 
mat. The address controller bits and address in- 
dex bits comprise the entire first-digit position 
of the address field. Four different two-bit and 
one-bit combinations can be specified by the 
two address controller bits as follows: 


a. 00 — unsigned four-bit 


format. Most signifi- 

cant address 

b. 01 — signed four-bit digit for the 
format. branch in- 


c. 10 — unsigned eight-bit structions 


format. 


d. 11 — indirect address. 


Any combination may be used except where 
prohibited by a specific instruction. The 
unsigned 4-bit format means that the data field 
consists of digits of information without a sign 
digit. The signed four-bit format specifies a dig- 
it data field with a sign digit preceding the 
most significant digit of the field. The field 
length does not include the sign digit position 
when a signed data field is specified. A bit con- 
figuration of 1101 is always treated as a minus 
sign (-), whereas any other bit configuration is 
considered as a plus sign (+). The unsigned 
eight-bit (character/byte) format specifies that 
the data field is in an internal eight-bit alpha- 
numeric code. The indirect address bit 
configuration specifies that the data field ad- 
dress is located at the specified base relative lo- 
cation. During the fetch cycle, another access 
must be made to obtain the specified field ad- 
dress. 


An indirect address must be even and is 
checked after indexing, if any. An odd indirect 


address is considered to be a non-synchronized 
address contained in an instruction and causes 
a processor interrupt. 


Address Digits 


Since the first digit of the address field com- 
prises the address index and controller bits, five 
digits remain for use as the data field address; 
however, addresses may generate beyond this 
seemingly maximum address of 099,999 by utiliz- 
ing the address controller bits at binary values 
up to a 2, thus creating an actual maximum ad- 
dress range per program of 000000 to 299,999. 
Programs exceeding the address of 099,999 can- 
not contain referenced data areas in excess of 
the 099,999 address. This address is always base 
relative and is added to the base register value 
during the fetch cycle. The absolute address 
stored in address memory is comprised of the 
value in the address field added to the base reg- 
ister. It can also be indexed by an index register 
when specified. The address digits are limited 
to the decimal digits zero through nine, thus 
creating a completely decimal addressing 
scheme for a beneficial system/programmer/ 
operator interface. 


Operator Code 


The first two digits of the first syllable repre- 
sent the operator code. This operator code is a 
decimal value ranging from 00 through 99, but 
all values are not used. All unassigned codes are 
reserved for expansion. If the processor receives 
any operator code that has not been assigned, 
an invalid instruction interrupt is generated. 
The operator code itself determines the number 
of syllables that must be fetched. 


Field Length 


For a majority of the instructions, the third, 
fourth, fifth, and sixth digits (D8 through D6) 
of the first syllable control the field lengths of 
the data fields (see figure 2-4). Digits D3 and 
D4 determine the A field length (AF), whereas 
digits D5 and D6 determine the B field length 
(BF). 


The field length values can range between 00 
and 99, inclusively. If a field length of 00 is 
specified, the field length is 100. The digits D3 
and D5 may also specify an indirect field 
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length. This is accomplished by making the D3/ 
D5 8-bit and 4-bit both equal to a 1. The base 
relative indirect address of the field length is 
obtained from the two low-order bits of D3/D5 
and the even values of the D4/D6 digit. Thus, 
the indirect field-length base relative address 
can be any even value from 00 through 38 for 
a total of 20 base relative addresses. 


D3 D4 D5 D6 


8 BIT 


4 BIT 


2 BIT 


1 BIT 


AF BF 


Figure 2-4. Field Length Digits 


Literal Specifications 


Some of the instructions allow the A field 
length digits to specify that the A address 
syllble contains a literal value and not the ad- 
dress of a data field. Figure 2-5 shows the bit 
configuration for the various literals that the A 
address syllable can contain. 


When D3 has the 8-bit and 2-bit ON with the 
4-bit OFF, the A address is a literal. The D3 
1-bit and D4 8-bit specify the format of the lit- 
eral. When the literal specification is an 
unsigned four-bit format, the literal length can 


8 BIT 
4 BIT 
Bigia: LITERAL 
LENGTH 
1 BIT 
UNSIGNED SIGNED 
4-BIT 4-BIT 
FORMAT FORMAT 


be one through six — the total number of digits 
in the address field. When the signed four-bit 
format is specified, the literal length can be one 
through five since the most significant digit is 
the sign digit.’ 


When the eight-bit format is specified, the lit- 
eral length can have a value of one through 
three. If the literal length is less than the 
maximum length for the specified format, the 
literal is always assumed to be left-justified. 


Read-Only Memory 


The read-only memory (ROM) within the proc- 
essor is a resistive-type of storage. It contains 
a set of microprograms that controls most of 
the actions taken by the processor. The micro- 
programs are initiated by the operation codes 
of program instructions after they are fetched 
from memory. The microprograms utilize the 
addresses stored in address memory during the 
execution of the instruction. 


HARDWARE INSTRUCTIONS 


The following list is a composite of all mnemon- 
ic operation codes used by the systems proces- 
sor. Assemblage of this list is only by general 
classification of the individual codes. 


Each operation code will be broken down into 
its associated descriptor. 


Data Movement Operation Codes 
The following operator codes are utilized to ma- 


nipulate data to and from different areas with- 
in the system. 


LITERAL 
LENGTH 


LITERAL 
LENGTH 


UNSIGNED 
8-BIT 
FORMAT 


Figure 2-5. Literal Specification Control 
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MOVE ALPHANUMERIC (MVA) 


The number of syllables is equal to two. The de- 
scriptor for the MVA operation is shown below: 


OP 
Code AF BF A Address B Address 
10 Length of Length of Address of Address of 
data field destination data field destination 
field field 
This instruction moves digits or characters 


from the A field (AF) and stores them at the 
location specified by the B address. The count 
in AF and BF specifies the length of the A and 
B fields, respectively. Up to 100 digits or char- 
acters may be moved, with the one-hundredth 
character specified by the count 00 in either 
length field. 


MOVE NUMERIC (MVN) 


The number of syllables is equal to two. The de- 
scriptor for the MVN operation is shown below: 


OP 
Code AF BF A Address 8B Address 
11 Length of Length of Address of Address of 
data field destination data field destination 
field field 


This instruction moves digits or the numeric 
portion of characters from a location specified 
by the A address to a location specified by the 
B address. The value within AF specifies the 
number of digits to be moved. The length of the 
destination field is contained in BF. 


MOVE REPEAT (MVR) 


The number of syllables is equal to two. The de- 
scriptor for the MVR operation is shown below: 


OP 
Code AF BF A Address B Address 
14 Length of Number of Most Most 
A field times that significant _—_ significant 
data data is to digit digit 
be moved (MSD) of (MSD) of 
to the B the data to the result 
field be moved field 
This instruction moves data from a location 


specified by the A address to a location 
specified by the B address. AF contains the 
number of digits or characters in the A field. 
BF specifies the number of times the entire A 
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field is to be moved to the B field. The length 
of the B field is the product of AF times BF. 


MOVE WORDS (MVW) 


The number of syllables is equal to two. The de- 
scriptor for the MVW operation is shown below: 


Code AF BF A Address B Address 
j2 Number of Address of Address of 
words to data to be designation 

be moved moved field 


This instruction moves words from a location 
specified by the A address and stores them in 
a location specified by the B address. At the 
completion of the instruction, both the A and 
B fields (AF and BF) contain identical informa- 
tion. 


MOVE WORDS AND CLEAR (MVC) 


The number of syllables is equal to two. This 
descriptor is identical to that of the MVW oper- 
ation, except for the following: 


a. The OP code is equal to 138. 


b. Zeros are written into the A location after 
each word has been moved. 


MOVE LINKS (MVL) 


The number of syllables is equal to three. The 
descriptor for the MVL operation is shown be- 
low: 


OP A B C 
Code AF BF Address Address Address 
09 Length of | Unused Instruction Addressed 

all fields 

(1 through 

100) 


This instruction is comprised of four syllables: 
the OP code, the AF variant, the BF variants, 
and three addresses. The AF variant specifies 
allowable data field lengths. These lengths are 
from 1 to 100 digits or characters. The final ad- 
dress controllers for all three addresses must be 
alike and can indicate unsigned numeric, signed 
numeric, or unsigned alpha information. 


During the execution of this instruction, the 
processor ignores the A and B controllers and 
uses the C controller to control all of the infor- 
mation fields. 
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Arithmetic Operation Codes 


The following operator codes are utilized to per- 
form arithmetic calculations. 


TWO ADDRESS ADD (INC) 


The number of syllables is equal to two. The de- 
scriptor for the INC operation is shown below: 


OP A B Cc 
Code AF BF Address Address Address 
01 “A” “B” field Address Address Address 
field length of addend of of 
length or augend result 
subtrahend or field 
minuend 


This instruction algebraically adds the contents 
of the A field to the contents of the B field. The 
sum is stored in the B address. 
THREE ADDRESS ADD (ADD) 
The number of syllables equals three. The ADD 
instruction is identical to the two address add 
instruction except for the following: 

a. The OP code is equal to 02. 


b. The sum is stored in the C address. 


TWO ADDRESS SUBTRACT (DEC) 
The number of syllables equals two. The DEC 
instruction is identical to the two address add 
instruction except for the following: 


a. The OP code is equal to 03. 
b. The difference is stored in the B address. 


THREE ADDRESS SUBTRACT (SUB) 

The number of syllables equals three. The SUB 
instruction is identical to the two address add 
instruction except for the following: 


a. The OP code is equal to 04. 


b. The difference is stored in the C address. 


MULTIPLY (MPY) 


The number of syllables equals three. The de- 
scriptor for the MPY operation is shown below: 
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OP A B C 
Code AF BF Address Address Address 
05 oA” “B” field Address Address Address 
field length of of of 
length multiplier multiplicand product 


This instruction algebraically multiplies the 
multiplicand specified by the B address by the 
multiplier specified by the A address and places 
the product into the address specified by C. 


AF and BF in this instruction specify the length 
of the A field and B field, respectively. These 
fields may specify from 1 to 100 digits, with the 
value of 00 representing a length of 100. The 
length of the C field will be the sum of AF and 
BF. 


DIVIDE (DIV) 


The number of syllables equals three. The de- 
scriptor for the DIV operation is shown below: 


OP A B C 
Code AF BF Address Address Address 
06 A field B field Address Address Address 
length length of divisor of of 
dividend quotient 
or 
remainder 


This instruction algebraically divides the con- 
tents of the B field by the contents of the A 
field and places the quotient in the C field. Any 
remainder as a result of the division will be 
found in the B field. 


Floating Point Arithmetic Operation Codes 


The following operation codes enhance the 
arithmetics of the system by allowing floating- 
point operation. 


FLOATING POINT ADD (FAD) 
The number of syllables is equal to three. The 


descriptor for the FAD operation is shown be- 
low: 


OP A B C 
Code AF BF Address Address Address 
80 Length Length Address Address Address 
of A of B of A field of B of C 
mantissa mantissa field field 
(not (not 
including including 
sign) sign) 


In floating point addition, the exponents of A 
and B must be made equal before algebraically 
adding the mantissa. Equalizing the exponents 
is accomplished by incrementing or 
decrementing the exponents of A or B_ ad- 
dresses, while effectively shifting the decimal 
point in the mantissa. 


FLOATING POINT SUBTRACT (FSU) 


The number of syllables equals three. The de- 
scriptor for the FSU operation is identical to 
that of the floating point add operation, except 
that the OP code is equal to 81. 


FLOATING POINT MULTIPLY (FMP) 


The number of syllables equals three. The de- 
secriptor for the FMP operation is shown below: 


OP A B C 
Code AF BF Address Address Address 
82 Length Length Address Address Address 
of A of B of of of 
mantissa mantissa multiplier multipli- product 
(not (not cand 
including including 
sign) sign) 
This instruction algebraically multiplies the 


contents of the B address by the contents of the 
A address and places the product into the loca- 
tion specified by the C address. 


FLOATING POINT DIVIDE (FDV) 


The number of syllables equals three. The de- 
scriptor for the FDV operation is shown below: 


OP A B CG 
Code AF BE Address Address Address 
83 Length Length Address Address Address 
of A of B of divisor of of 
mantissa mantissa dividend quotient 

or 
remainder 


This instruction algebraically divides the con- 
tents of the B address by the contents of the 
A address and places the quotient into the loca- 
tion specified by the C address. Any remainder 
is found at the location specified by the B ad- 
dress and has the same exponent as the original 
B field (BF). The length of the C mantissa is 
the difference between AF and BF. 


Logical Operation Codes 


The following operation codes affect certain log- 
ic areas within the system. 


TRANSLATE (TRN) 


The number of syllables equals three. The de- 
scriptor for the translate operation is shown be- 
low: 


OP 
Code AF BF A Address B Address 
15 Number Address Address Address 
of of data of of result 
characters to be translate field 
to be translated table 
translated 


The translate instruction translates characters 
from the A field by the table in the B field and 
stores them in the C field. The number of char- 
acters to be translated is contained in the four 
digit number combined in the AF and BF vari- 
ants. The maximum number of characters is 
10,000, represented by 0000 in AF and BF. The 
A character is used to determine the address in 
the translate table of the new character. 


SCAN TO DELIMITER - EQUAL (SDE) 


The number of syllables equals two. The de- 
scriptor for the SDE operation is shown below: 


OP 
Code AF BF A Address B Address 
16 Number of Number of Address of Address of 
delimiter(s) digits or the data 
characters delimiter(s) 
in the data 
field 


This instruction informs the programmer of the 
presence or absence of any delimiter(s) and the 
location of the delimiter(s). The delimiter isa 
character, or group of characters used to ter- 
minate the instruction. The SDE instruction 
counts the number of digits or characters prior 
to a delimiter. The AF and BF variants can 
specify up to 100 digits or characters with the 
value of 00 being equal to 100. 


SCAN TO DELIMITER - UNEQUAL (SDU) 
The number of syllables equals two. This 


operation is identical to the scan to delimiter 
— equal operation except for the following: 
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a. The OP code is equal to 17. 


b. The SDU counts the number of delimiters 
before a character is found that is not a 
delimiter. 


SCAN TO DELIMITER - ZONE EQUAL 
(SZE) 


The number of syllables equals two. This 
operation is identical to the scan to delimiter 
— equal operation except for the following: 


a. The OP code is equal to 18. 


b. The SZE operation utilizes the zone portion 
of the code being used (ASCII or EBCDIC). 


SCAN TO DELIMITER - ZONE UNEQUAL 
(SZU) 


The number of syllables equals two. The SZU 
operation is identical to the scan to delimiter — 
unequal operation except for the following: 


a. The OP code is equal to 19. 


b. The SZU operation utilizes the zone portion 
of the code being used (ASCII or EBCDIC). 


BIT ZERO TEST (BZT) 


The number of syllables equals one. The de- 
scriptor for the BZT operation is shown below: 


OP . 
Code AF BF A Address 
40 Length of A Mask of bits Address of 
field to be tested data to be 
tested 


This instruction is used to test for a bit or bits 
in the zero state of a string of digits or charac- 
ters. The bits of a digit or character to be tested 
are indicated by the two-digit mask located in 
the BF position of the instruction. The AF posi- 
tion indicates the length of the information 
tested in digits or characters. 


BIT ONE TEST (BOT) 
The number of syllables equals one. The BOT 
operation is identical to the bit zero test 


operation except for the following: 


a. The OP code is equal to 41. 


b. The operation is used to test for a bit or 
bits in the one state. 


AND (AND) 


The number of syllables equals three. The de- 
scriptor for the AND operation is shown below: 


OP A B C 
Code AF BF Address Address Address 
42 Length Length Address Address Address 

of the of the B” of the A of the B- of the 

A field field field field logical 

result 


This instruction will provide a logical result of 
two fields: the two fields of data are addressed 
by the A and B addresses. The logical result is 
stored at the location specified by the C ad- 
dress. 


The field lengths of A and B are indicated by 
the AF and BF variants, respectively. The 
length of the C Field is equivalent to the length 
of the longer field: A or B. The field lengths can 
be from 1 to 100 digits or characters, with a val- 
ue of 00 indicating a field length of 100. 


The AND instruction will produce a bit-by-bit 
logical product of the A and B fields. The result 
bit will be set if the corresponding bits are both 
set in the A and B fields. Figure 2-6 contains 
a truth table for the AND instruction in which 
A and B are corresponding bits of the data 
fields and C is the corresponding result bit. 


A B Cc 
ADDRESS | ADDRESS} RESULT 


ee ee ee 
a a ee 


Figure 2-6. ‘‘AND”’ Truth Table 
OR (ORR) 


The number of syllables equals three. The ORR 
instruction is identical to the AND instruction 
except for the following: 


a. The OP code is equal to 48. 


b. The ORR instruction will set a bit in the 
result field if either corresponding bit in the 
A or B fields is equal toone. Refer to figure 


2-7. If the A and B fields are of unequal 
length, then the shorter field is made equal 
to the longer by assuming trailing zeros. 


pooner ESS poones ate 


1 


Figure 2-7. ‘‘ORR"’ Truth Table 


NOT (NOT) 


The number of syllables equals three. The NOT 
instruction is identical to the AND instruction 
except for the following: 


a. The OP code is equal to 44. 


b. The NOT instruction will set a bit in the 
result field if a corresponding bit is on in ei- 
ther the A or B fields, but not on in both (ex- 
clusive OR). 


Refer to figure 2-8 for the NOT truth table. If 
the A and B fields are of unequal length, the 


shorter field is made equal to the longer by as- 
suming trailing ones. 


A B Cc 
ADDRESS | ADDRESS} RESULT 
0 


a a ae 
fie tee ee 
ae ae as 


Figure 2-8. ‘‘NOT”’ Truth Table 


SEARCH (SEA) 


The number of syllables equals three. The de- 
scriptor for the SEA operation is shown below: 


OP 
Code AF BF 
34 Length of A field B field 
increment 


The A field (AF) contains the length of the 
mask and the search is from the B field to the 
C address in accordance with the C controller. 
The C controller specifies the type of search, as 
follows: Equal, Low, or Lowest. 


COMPARE ALPHANUMERIC (CPA) 


The number of syllables equals two. The de- 
secriptor for the CPA operation is shown below: 


OP 
Code AF BF A Address B Address 
45 Number of Number of Address of Address of 
characters characters the data the 
in the data in the field reference 
field reference field 
field 


This instruction compares the characters in the 
A field to the characters in the B field. The 
comparison indicators are set to indicate wheth- 
er the A field is less than the B field (low), 
equal to the B field (equal), or greater than the 
B field (high). The count in AF and BF specifies 
the number of characters in their respective 
fields. The fields may be of unequal length. 


COMPARE NUMERIC (CPN) 


The number of syllables equals two. The de- 
scriptor for the CPN operation is shown below: 


OP 
Code AF BF A Address’ B Address 
46 Number of Number of Address of Address of 
digits or digits or data to be reference 
characters characters compared. field. 
in the A in the B 
field. field. 


This instruction compares the numeric data of 
the A field with the numeric data of the B field. 
The comparison indicators are set according to 
the result of the comparison. 


The AF and BF variants can designate a num- 
ber of digits from 01 through 99 or 00 which 
represents 100. If the variants are not equal, 
the shorter field is assumed to have leading 
zeros until the field lengths are equal. 
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EDIT (EDT) 


The number of syllables equals three. The de- 
scriptor for the EDT operation is shown below: 


OP A B C 
Code AF BF Address Address Address 
49 Reserved: Number Address Address Address 
must be of micro- of data of micro- of 
equal to operations operators. result 
zero. in the B field. 
field. 


This instruction moves data from the A field to 
the C field in a manner specified by micro-oper- 
ators in the B field. This instruction is used to 
mask data into a format which would normally 
be used on output media. That is, for business 
transactions it would insert the dollar signs, 
commas and periods in the appropriate places 
in the data for printing. For other operations, 
it may insert dashes, negative or positive signs, 
or whatever else is deemed necessary. 


The count in BF may specify up to 100 micro- 
operators, with 100 indicated by 00. 


Address Branching 


The following operator codes are utilized for ad- 
dress manipulation within the system. 


NO OPERATION (NOP) 


The number of syllables equals one. The de- 
scriptor for the NOP operation is shown below: 


OP 
Code AF BF 
20 NOT USED 


This instruction has no logical function. 
BRANCH ON LESS THAN (LSS) 


The number of syllables equals one. The de- 
scriptor for the LSS operation is identical to the 
no operation instruction except the OP code is 
equal to 21. 


This instruction results in a branch if the com- 
parison indicators are low as a result of a prior 
instruction. If the comparison is other than low 


(either greater or equal), the operation is a 
NOP. 
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BRANCH ON EQUAL (EQL) 


The number of syllables equals one. The de- 
scriptor for the EQL operation is identical to 
the no operation instruction except the OP code 
is equal to 22. 


This instruction results in a branch if the com- 
parison indicators are equal as a result of a pri- 
or instruction. If the comparison is other than 
equal (either greater or low), the operation is 
a NOP. 


BRANCH ON EQUAL OR LESS THAN 
EQUAL (LEQ) 


The number of syllables equals one. The de- 
scriptor for the LEQ operation is identical to 
the no operation instruction except the OP code 
is equal to 23. 


This instruction results in a branch if the com- 
parison indicators are equal or less as a result 
of a prior instruction. If the comparison is other 
than equal or less the operation is a NOP. 


BRANCH ON GREATER (GTR) 


The number of syllables equals one. The de- 
scriptor for the GTR operation is identical to 
the no operation instruction except the OP code 
is equal to 24. 


This instruction results in a branch if the com- 
parison indicators are greater as a result ofa 
prior instruction. If the comparison is other 
than greater (either less or equal), the operation 
is a NOP. 


BRANCH ON NOT EQUAL (NEQ) 


The number of syllables equals one. The de- 
scriptor for the NEQ operation is identical to 
the no operation instruction except the OP code 
is equal to 25. 


This instruction results in a branch if the com- 
parison indicators are high or low as a result 
of a prior instruction. If the comparison is other 
than high or low, the operation is a NOP. 


BRANCH ON GREATER THAN OR EQUAL 
(GEQ) 


The number of syllables equals one. The de- 
scriptor for the GEQ operation is identical to 


the no operation instruction except the OP code 
is equal to 26. 


This instruction results in a branch if the com- 
parison indicators are equal or greater as a re- 
sult of a prior instruction. If the comparison is 
other than equal or greater, the operation is a 
NOP. 


BRANCH UNCONDITIONALLY (BUN) 


The number of syllables equals one. The de- 
scriptor for the BUN operation is identical to 
the no operation instruction except the OP code 
is equal to 27. 


This instruction does not sample the 
comparison indicators, but rather branches re- 
gardless of their value. 


BRANCH ON OVERFLOW (OFL) 


The number of syllables equals one. OFL 
operation is identical to the no operation in- 
struction except the OP code is equal to 28. 


This instruction branches if the OVERFLOW 
flip-flop is set. 


Branching Operator Codes 
The following operating codes are provided for 
data and operation branching while remaining 
in the same hardware flow. 


ENTER (NTR) 


The number of syllables equals one. The de- 
scriptor for the NTR operation is shown below: 


OP 
Code AF BF A Address Pp ——P 
31 Number of Branch address Parameters 
parameters in of the or data, 
character, if AF instruction if required 


and BF equal 00, 
no parameters 
are required 


This instruction is used to allow a branch to a 
string of program instructions (referred to as 
a subroutine) followed by a return from the 
subroutine to the instruction following the NTR 
instruction. This allows a program to use an 
identical string of instructions (subroutine) in 
several locations within a program with the in- 
structions written only once. 


EXIT (EXT) 


The number of syllables equals one. The in- 
struction for the EXT operation is shown below: 


OP 
Code A Address 
32 Branching address of this instruction 


This instruction is basically an address branch 
instruction with the exception that its primary 
use is for exiting from subroutines. This in- 
struction will have the opposite effect on the 
programmatic stack that the enter instruction 
had; that is, the enter instruction constructed 
a stack entry and then branched to a subrou- 
tine, the exit instruction will delete this stack 
entry and branch out of the subroutine. 


BRANCH COMMUNICATE (BCT) 


The number of syllables equals zero. The de- 
scriptor for the BCT operation is shown below: 


OP 
Code AF BF 
30 Communicate 
address 


This instruction is used to allow a program to 
branch to the MCP. The instruction can be used 
programmatically or it can be hardware gener- 
ated. In either case, the AF and BF portion of 
this instruction is the address of a communicate 
address in the control program. 


The branch communicate instruction will store 
sufficient information into the MCP area of 
memory to allow a program to be reinitiated by 
the Reinstate instruction. The instruction can 
be generated in normal state if an interrupt ex- 
ists during a fetch operation. It can also be gen- 
erated if an interrupt exists and the Reinstate 
instruction is executed while in control state. 


Privileged Operation Codes 
The following operation: codes are classified as 


privileged operators in that they may be uti- 
lized only in zero-base mode. 


BRANCH REINSTATE (BRE) 


The number of syllables equals zero. The de- 
scriptor for the BRE operation is shown below: 
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OP 
Code AF BF 
90 Normal and control Unused 


state indicator 


The Reinstate is a privileged instruction that is 
used by the MCP to initiate a program on the 
processor. This instruction consists of the “AF” 
and “BF” variants and no addresses. 


The Reinstate instruction will transfer to the 
processor registers from absolute addresses 64 
through 76 the information needed to enter a 
program. This information is located in 
memory in the following manner: 


a. 64 - 69 — Program address. The address 
of the first instruction to be executed in the 
program being initiated. 


b. 70 - 72 — The base address of the program. 


c. 73 - 75 — The limit address of the pro- 
gram. 


d. 76 — The value of the COMPARISON, 
OVERFLOW and MODE flip-flops. 


The AF variant indicates if the program initi- 
ated is to be in normal or control state. If AF 
= 1, then the NORMAL flip-flop is set to put 
the processor into normal state. The BF variant 
is not used by this instruction. 


If the Reinstate instruction is entered with the 
INTERRUPT flip-flop set, the instruction is 
changed to the branch communicate (OP code 
= 380) with the address of 0094. This will pre- 
vent an entry to normal state when an inter- 
rupt condition exists in the processor. 


INITIATE (IIO) 


The number of syllables equals one. The de- 
scriptor for the IIO operation is shown below: 


OP 
Code AF BF A Address 
94 Not Used Channel Address 
number of the of 
I/O control the 
that is to I/O 


receive the I/O descriptor. 
descriptor 


This instruction is a privileged instruction and, 
as such, the base address register must be equal 
to zero in order for it to be validly executed. 


The purpose of the Initiate instruction is to 
read an I/O descriptor out of memory and route 
it to the appropriate places. As such, it serves 
as a fetch for I/O instructions (descriptors). 


The address of the descriptor must specify 
unsigned. numeric or indirect addresses. If an 
indirect address is used, the final address must 
specify unsigned numeric. 


READ ADDRESS (RAD) 


The number of syllables equals one. The de- 
scriptor for the RAD operation is shown below: 


OP 

Code AF BF A Address 

92 Refer to text I/O channel Storage 
designate Address 


Read address is a privileged instruction and, as 
such, is only valid when the base register is 
equal to zero. The A storage address may 
specify indirect addressing. Whether it is direct 
or indirect addressing it must ultimately be an 
even address and specify unsigned numeric. 


The action taken by the instruction is deter- 
mined by the least significant digit (LSD) of 
AF. If AF is equal to 0, the begin word of the 
designated channel is moved into the A field. 
If AF = 01, the end word is moved into the A 
field. If AF = 09, six digits in the A field are 
written into the begin and end words of the des- 
ignated channel. I/O Channels “0” through 19 
may be designated by BF. 


In order for the Read Address instruction to be 


valid, it must be executed with the designated 
I/O channel not-busy. 


READ AND CLEAR TIMER (RCT) 


The number of syllables equals one. The de- 
scriptor for the RCT operation is shown below: 


OP 
Code AF BF A Address 
95 not used Storage 
Address 


The Medium Data Processing Systems have a 
built-in one millisecond timer for logging pur- 
poses. Address memory words G and H are 
reserved for timer operations. Word G is 
referred to as the first timer word and it is used 
to count one millisecond time intervals. The 
maximum count that may be stored in word G is 
999,999 milliseconds or approximately 16.67 
minutes. 


Word H, the second timer word, may be pro- 
grammatically set to any value of 0 through 
999,999. Each time word G is incremented, it 
is compared to word H. 


The A address must be even and may specify 
unsigned numeric or Indirect Addresses. If indi- 
rect addressing is indicated, the final address 
must specify unsigned numeric. 


The RCT operation causes the contents of the 
first timer word (G) to be placed into core mem- 
ory starting at the location given by the A ad- 
dress and set the contents of the first timer 
word to zero. 


READ TIMER (RDT) 


The number of syllables equals one. The RDT 
instruction is identical to the read and clear 
timer instruction except for the following: 


a. The OP code is equal to 96. 


b. The RDT operation causes the contents of 
the first timer word to be placed into core 
memory starting at the location given by the 
A address without disturbing the word G con- 
tents. 


SET TIMER (STT) 


The number of syllables equals one. The STT 
instruction is identical to the read and clear 
timer instruction except for the following: 


a. The OP code is equal to 97. 


b. The STT operation causes the second timer 
word (H) to set the value contained at the lo- 
cation specified by the A address. 


SCAN RESULT DESCRIPTOR (SRD) 


The number of syllables equals one. The de- 
scriptor for the SRD operation is shown below: 
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OP 
Code ar BE 
91 Address of the first result 


descriptor to be scanned. 


This privileged instruction is used by the Oper- 
ating System to test for the presence of a Re- 
sult Descriptor Completion and Exception in re- 
served memory. In addition, a test is made to 
determine if an Exception condition has oc- 
curred. 


Miscellaneous Operator Codes 


The following operator codes are utilized but 
not categorized in specific locations. 


SET MODE (SMF) 


The descriptor for the SMF operation is shown 
below: 


OP 
Code AF BF 
47 This variant designates the action Unused 


of setting or resetting the ASCII 
(ASC) flip-flop. 


This instruction is used to place the processor 
into the EBCDIC or ASCII mode of operation. 
This instruction is a no-address instruction that 
uses only the high order digit of the AF variant. 
The BF variant is not used for this instruction. 


If AF is equal to one, the instruction will place 
the processor into the ASCII mode of operation 
by setting the ASC flip-flop. If AF is equal to 
zero, the instruction will reset the ASC flip-flop 
and place the processor into the EBCDIC mode 
of operation. If AF is not equal to 0 or 1, then 
the instruction will perform no logical function. 
In effect, it will act as a NOP. 


HALT, BRANCH (HBR) 


The number of syllables equals one. The de- 
scriptor for the HBR operation is shown below: 


OP 
Code A Address 
29 Branch address of this instruction 


This instruction is basically an address branch 
instruction with the ability to stop the 
operation of the processor. Depending upon the 
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value of this digit and the status of the NOR- 
MAL/CONTROL STATE flip-flop, the proces- 
sor will execute Halt, Ignore Halt, or treat the 
HBR instruction as an invalid instruction. 


HALT, BREAKPOINT (HBK) 


The number of syllables equals zero. The de- 
scriptor for the HBK operation is shown below: 


OP 
Code AF BF 
48 Unused Contains the 
breakpoint 
mask digits 


This instruction is a halt that is conditioned by 
a comparison between the mask in the BF field 
and the contents of base relative 46 and the halt 
execution digit in absolute address 77. The 
mask and base relative 46 digits are used to in- 
dicate if the program being executed requires 
this halt. The contents of absolute address 77 
indicates the type of action to occur: execute the 
halt, ignore the halt, or consider the HBR an 
invalid instruction. If the halt is executed, oper- 
ator intervention is required to restart the proc- 
essor by the depression of the STOP/RUN or 
the SINGLE INSTRUCTION button. The halt 
will have no affect on any I/O operations that 
are in progress. Only processor actions will be 
stopped. 


PROCESSOR RESULT DESCRIPTORS 


All processor interrupts that do not turn off the 
processor clock generate a result descriptor. 
‘The INTERRUPT flip-flop is not necessarily 
set. The format of the result descriptor is 
shown in figure 2-9. 


The result descriptor is a complete memory 
word of 16 bits, with bit 1 being the most sig- 


nificant. The function of each bit is shown in 
table 2-1. 


DIGIT 1 


BIT 


DIGIT 2 DIGIT 3 DIGIT 4 


Figure 2-9. Processor Result Descriptor 


Table 2-1. Bit Functions of Processor Result 
Descriptor 


This bit is ON whenever a result 
descriptor is stored. 


This bit is ON whenever an 
exceptional condition occurs (always 
ON whenever a result descriptor is 
stored). 


This bit is reserved. 
This bit is ON if the interrupt was 


generated by the execution of an 
invalid I/O operation. 


This bit is ON if the interrupt was 
generated by the execution of an 
invalid instruction. 


This bit is ON if the interrupt was 
caused by a memory parity error. 


This bit is ON if the interrupt was 
caused by a memory address error. 


This bit is ON if the interrupt was 
caused by an instruction time out. 


This bit is ON if the interrupt was 
caused by the clock interrupt. 


This bit is ON if the interrupt was 
caused by an operator. 


11-16| These bits are reserved. 


If a processor interrupt is generated, reserved 
memory will contain a word with bit 1, bit 2, 
and one or more of the other specified bits ON. 
When the result descriptor is handled, the first 
two bits must be turned OFF by the Operating 
System. The privileged instruction (Scan Result 
Descriptor) is used by the Operating System to 
sense the presence of a result descriptor in re- 
served memory. 


NORMAL STATE INTERRUPTS 


When certain operational conditions occur 
within the processor while executing instruc- 
tions in the normal state, the following logic oc- 
curs: 


a. If either an operator interrupt, a timer in- 
terrupt, or an I/O interrupt occurs, the inter- 
rupt will generate a result descriptor and 
store the descriptor in the reserved address 
memory location. 


b. The interrupt will set the interrupt flip- 
flop and store the program return point and 
logical register settings. 


c. An automatic branch is taken to the ad- 
dress specified by the contents or reserved 
address memory location 000094. The proces- 
sor operational mode is changed from normal 
state to control state, zero base. 


The branch to the control state is a branch to 
the Operating System — the Master Control 
Program. It is the function of the Operating 
System to determine the type of interrupt and 
the course of action that is to be followed. The 
interrupt system, as explained, is automatic 
and is an integral part of the processor hard- 
ware system. 


Memory Parity Error 


When a memory parity error is sensed during 
a processor access from main memory, an inter- 
rupt occurs. (The instruction is continued until 
completion if the error did not occur during 
fetch.) The instruction being executed is com- 
pleted before allowing the automatic interrupt 
system to become operative. 


Address Error 


A memory address error can occur under any 
of the following conditions: 


a. Base or limit address error. 
b. Non-synchronized address of instructions. 


c. Non-synchronized addresses contained in 
instructions. 


d. Non-decimal digits contained in addresses. 


Detection of address errors is made on those 
addresses developed after the addition of the 
base and index register, if applicable, and on all 
developed addresses which are advanced during 
the execution of the instruction. Note that when 
the base or index register is added to an address 


containing a non-decimal digit, the resultant 
address may be changed to an undefined ad- 
dress which no longer contains a non-decimal 
digit and, therefore, will not be detected. Detec- 
tion of non-synchronized addresses contained in 
instructions is limited only to addresses which 
are used to write into memory. 


If any of the above four error conditions occurs, 
the instruction is completed, but all memory 
write cycles are inhibited. A memory read cycle 
is inhibited only when an address contains a 
non-decimal digit. However, when addresses 
are advanced during the execution of an in- 
struction, non-decimal digits may be changed to 
decimal digits, allowing a memory read or write 
cycle to be performed. 


When one of the above error conditions occurs 
and an instruction is completed, an interrupt is 
generated and the automatic interrupt system 
takes over control. A base or limit address error 
occurs whenever a memory address is out of 
bounds of the base and limit register settings. 
This feature provides for memory protection 
when operating in a multiprogramming mode. 


Non-synchronized addresses of instructions is 
an error when a branch occurs to an address 
that is not an even value (modulo 2). An error 
that results from non-synchronized addresses 
contained in an instruction is caused when an 
address is not modulo 2 or modulo 4 when re- 
quired by the format control bits or the instruc- 
tion code. A non-decimal digit in an address is 
a digit that has a binary value of 10 through 
15 and is referred to as an undigit. 


Instruction Time-Out 


When an instruction is fetched, an adjustable 
timer of approximately 250 milliseconds is 
triggered. If execution of the instruction is not 
completed during the preset time, an interrupt 
is generated immediately. This does not include 
actual I/O operations, since the processor only 
initiates them, whereas the I/O control unit ex- 
ecutes them. 


The contents of the reserved location for the 
next instruction address may or may not have 
meaning. 
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Invalid Instructions 
An invalid instruction is defined as follows: 
a. All non-assigned operator codes. 


b. Operator codes requiring options which are 
not present. 


ce. Invalid Branch Communicate instruction. 
d. Invalid halts. 


e. Privileged instructions during non-zero 
base state operation. 


If any of these conditions occur, the absolute 
address of the invalid instruction is stored in 
the memory location reserved for the program 
address. Execution of the instruction and all 
memory write cycles are inhibited. 


Privileged Instructions 


There is a set of instructions that can only be 
executed in zero-base state. If one of these priv- 
ileged instruction codesis detected while oper- 
ating in non-zero-base state, an interrupt is 
generated. Memory write cycles are inhibited, 
no instruction is executed, and the memory lo- 
cation reserved for the program address con- 
tains the absolute address of the privileged in- 
struction. 


Clock Interrupt 


Two words that comprise the timer and its con- 
trol value are contained within address 
memory. The first timer word is counted at a 
one millisecond rate. The second timer word 
can contain any six-decimal digit value. When 
the real timer word is counted to the value of 
the control, the clock interrupt is generated. 
The real timer value will continue to count and 
requires the MCP to read and clear this value 
from the address memory location. The 
maximum value that the real timer word can 
achieve is 999,999 milliseconds. In any event, 
the current instruction is completed before au- 
tomatic interrupt handling takes place. 


CONTROL STATE INTERRUPTS 


When the processor is operating in control 
state, there are interrupt conditions generated, 
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but no automatic interrupt handling takes place . 
at the completion of an instruction. Rather, at 
the time that the MCP attempts to return to 
normal state, automatic branching to control 
location 000094 will occur so that these inter- 
rupts will be handled by the MCP. 


If the processor is operating in the zero-base 
state, the following processor conditions will 
cause the processor clock to be turned off, leav- 
ing all conditions static: 


a. Memory parity error interrupt. 
b. Address error interrupt. 

c. Instruction time out interrupt. 
d. All non-assigned operator codes. 


e. Operator codes requiring options which are 
not present. 


f. Invalid halts. 


Since the processor is in the zero-base state, 
any of the above interrupts indicates that a 
hardware or an Operating System error exists. 
A privileged instruction interrupt cannot occur 
because all of the instructions are executable in 
the zero-base state. The clock interrupt condi- 
tion occurs in the same manner as in normal 
state, but no automatic branching occurs in 
control state. 


Invalid 1/O Operation 


Since the zero-base state must be entered to ex- 
ecute an initiate I/O operation, it is possible to 
have an invalid I/O descriptor which will set 
the interrupt flip-flop ON and store a result de- 
seriptor. Automatic interrupt branching occurs 
in normal state, but not in control state. An in- 
valid I/O operation interrupt can occur under 
any of the following conditions: 


a. The specified I/O channel is not attached 
to the system. 


b. The I/O descriptor for the specified chan- 
nel is an invalid operation. 


c. An attempt is made to initiate an I/O oper- 
ation on a channel that is busy with a previ- 
ously initiated operation. 


d. The addresses within the I/O descriptor 
are not valid (not synchronized, non-decimal 
digits, or the ending address is not greater 
than the beginning address). 


STACK 


The memory stack was previously mentioned 
with respect to storing the mode, overflow, and 
comparison flip-flop status prior to entering a 
subroutine. The stack is an area of memory 
that has been reserved by the programmer in 
which to store subroutine linkage words. The 
beginning address of the stack is stored in the 
base relative reserved memory location 000040. 
when an Enter instruction is executed, the ad- 
dress of the stack is obtained from base relative 
location 000040 and into this stack is 
automatically stored: 


a. The six-digit address of the next instruc- 
tion. 


b. The eight-digit contents of Index Register 
Ds 


c. One character containing the status of the 
mode, overflow, and comparison flip-flops. 


d. The parameters as specified by the Enter 
instruction. 


Index Register 3 is set to the address of the be- 
ginning of the stack, and reserved memory loca- 
tion 000040 is set to the address following the 
parameters (beginning of the next stack) in the 
event that another subroutine is entered from 
the one that is being executed. As additional 
nested subroutines are entered, the same stor- 
age process of linkage words into the stack 
takes place. As the subroutines are exited, re- 
turn to the preceding level occurs by restoring 
the values of registers from the stack linkage 
words. These exits occur until the object pro- 
gram is reached at which time IX8, the address 
in 000040, and the logical flip-flops are restored 
to the conditions existing at the time of the 
first Enter instruction execution. This stack 
concept greatly simplifies the ability to call on 
subroutines and to make nested calls on other 
subroutines. 


Adder 


The processor uses an adder that accumulates 
two fields from the most significant to the least 


significant digit positions. Reverse addition has 
the advantage of detecting an overflow condi- 
tion prior to altering the receiving field for the 
result. The principle used in this type of adder 
is illustrated by the flow chart in figure 2-10 
and the five examples in figure 2-11. If the data 
fields are signed, sign manipulation takes place 
prior to the addition since they are the most 
significant digits. 


In figure 2-11, there is no manipulation of signs 
shown. The addition of two data fields is only 
shown to present the technique of a left-to-right 
adder. 


In example 1, as each set of digits is added, no 
carry is generated and no nines are produced. 
As each new result is generated by the adder, 
the previous result is stored in the result field 
in core memory. In example 2, an overflow con- 
dition is immediately detected because of a car- 
ry on the first digit addition. In example 3, the 
first five nines are not stored until the result 
equal to eight is generated. The eight is re- 
tained until the carry is generated when adding 
the last digits, at which time the eight is made 
into a nine and stored. The following nines are 
then stored as zeros in the receiving field, and 
then the final digit (8) is stored. Nothing is 
stored in example 4 until the final digits are 
added. The receiving field in example 5 remains 
unchanged even though an overflow condition 
is not detected until the final digits are added. 
This is due to the result being contained in the 
nine’s counter of the adder. 


Floating Point Representation 


In addition to fixed point arithmetic, the proc- 
essors are capable of performing floating point 
arithmetic. If floating point arithmetic is used, 
the numeric data must be in the specific format 
shown in figure 2-12. 


The first digit (D1) of the field is the sign of 
the exponent and specifies whether the expo- 
nent is positive or negative. The actual value of 
the exponent is contained in the second and 
third digit (D2 and D3) positions of the field. 
The first three digits allow the exponent value 
to range from -99 to +99, a very large range. 
The fourth digit (D4) always indicates the sign 
of the mantissa. The mantissa is variable in 
length from 1 to 100 and is contained in posi- 
tions D5 through Dn, as required. The mantissa 
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T2-S 


ADO 
CORRESPONDING 
DIGITS OF 


DATA FIELDS 


WERE 
THESE 
THE Ist 
DIGITS 


SET 

THE 
OVERFLOW 
FLIP-FLOP 


AOD ONE 


TO THE 
& ° 


COUNTER 


HAVE ALL 
DIGITS 
BEEN 

ADDED 


DOES 
REGISTER 
CONTAIN 
A RESULT 


YES 


NO 


YES 


NO 


STORE THE 
REGISTER 


INTO 
MEMORY 


DOES THE 
REGISTER 
CONTAIN 
A RESULT 


STORE THE 
REGISTER 


DOES THE 
REGISTER 
CONTAIN 
A RESULT 


ADD ONE 
TO THE 
RESULT IN 


THE REGISTER 


PLACE THE 
NEW RESULT 
IN THE 
REGISTER 


DOES 
THE 9's 
COUNTER 

=0 


STORE THE PLACE THE 
REGISTER NEW RESULT 
IN IN THE 


MEMORY REGISTER 


Figure 2-10. 


STORE A 9 
IN MEMORY & 
(9's COUNTER) 
- 1 


DOES 
THE 9's 
COUNTER 


Adder Functional Flow Chart 


DOES 
THE 9's 
COUNTER 
=0 


STORE A 9 
NO IN MEMORY & 


(9's COUNTER) 
- | 


YES 


STORE A 0 
IN MEMORY & 
(9's COUNTER) 
- 1 


is always a whole number with the decimal Table 2-2. Floating Point Representation 
point assumed to the right of the last digit. Sev- 
eral examples of floating point data are shown 
in table 2-2. 


Floating Point Data 


+123 +004+123 


-1.23 -02-128 
+0.0057 ~04+57 
-9.786 x 10-° -09-9786 
+3.75 x 10° +04+375 


EXAMPLE 1: 


RESULT 


4 
D104 
2 


EXAMPLE 2: 


SIGN OF 
MANTISSA 
EXPONENT 


SIGN OF EXPONENT 


MANTISSA 


12345 
92345 
RESULT 1: 0 + CARRY 
FINAL RESULT: OVERFLOW FLIP-FLOP SET 


Figure 2-12. Floating Point Data Format 


EXAMPLE 3: 


LOAD FUNCTION 


eae’ Two t f load d ilable. Th 

wo types of load commands are available. The 
a ETE first type, called Universal Load, permits the 
operator’s selection of the input media; the sec- 


RESULT 1: 999998998 + CARRY 


FINAL RESULT: 999999008 ond type, called Normal Load, restricts the se- 
lection of the input media to that of a 
particular peripheral unit (normally systems 


EXAMPLE 4: memory or disk). The two types of load com- 
eye ee mands are discussed in the following 
0876543 paragraphs. 


0123457 
RESULT 1: 0999990 + CARRY 
FINAL RESULT: 1000000 The Normal Load operation is initiated by 
clearing the computer by pressing the CL 
(clear) key and the LD (load) key. Pressing the 
LD key writes a 2-digit channel number and the 
first syllable of an I/O descriptor into reserved 
memory starting at address 000000. The chan- 
876543 nel number and I/O descriptor are 
123457 predesignated by the user and are field engi- 
RESULT 1: 999990 + CARRY neering modifications. To retrieve a new copy 
FINAL RESULT: OVERFLOW FLIP-FLOP SET of the MCP by the quickest means available re- 
quires that the LD key be wired to call on the 
appropriate disk channel on which the resident 
MCP is stored. After writing the channel num- 
Figure 2-11. Adder Examples ber and I/O descriptor into core memory, the 


Normal Load 


EXAMPLE 5: 
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processor will initiate an I/O operation using 
the information in address 000000. The hard- 
ware automatically sets the beginning address 
to 001000 and the ending address to 001400. If 
the I/O unit is systems memory or a disk file, 
the segment address is set to zero. The proces- 
sor idles until the interrupt flip-flop is set by 
the I/O control unit at the completion of the 
I/O operation. The processor then automatical- 
ly branches to absolute address 001000 and be- 
gins executing the program that was just 
loaded. If an exception condition occurs, the 
Load operation must be repeated by the sys- 
tems operator. It must be noted that if the 
I/Ounit is designated as systems memory or 
disk, a previously cold-started MCP or MCP 
loader operation must have been accomplished 
after a power-off condition. 


Universal Load 


The Universal Load operation is initiated by the 
operator in the following manner: 


a. Press the STOP/RUN key to stop the sys- 
tem. 


b. Press the CL (clear) key to clear the sys- 
tem. 


c. Press the AD key and then the WR key. 


d. Starting at absolute address 000000, enter 
the two digits for the channel number and 
the six digits (first syllable) of the I/O de- 
scriptor. This allows the operator to select 
any channel and the input peripheral unit 
which contains the cold-start or MCP loader 
deck (or images). 


e. Press the OP key and enter OP Code 66 into 
the OP register by typing 660000 on the 
keyboard. 


f. Press the STOP/RUN key to start the sys- 
tem. 


When the STOP/RUN key is pressed at this 
point, the processor executes a Load operation 
that selects the control program from a “SYS- 
TEM” magnetic tape and loads it. The processor 
will now go into a pseudo initiate I/O cycle in 
which the channel number and the first syllable 
of an I/O descriptor are obtained from core 
memory starting at address 000000. 


The beginning and ending addresses for the 
I/O descriptor are set to 001000 and 001400, re- 
spectively and the segment number, when sys- 
tems memory or a disk file is used, is set to 
zero. Having completed the initiate I/O cycle, 
the processor idles until the interrupt flip-flop 
is set, signifying completion of the I/O 
operation. When the interrupt flip-flop is set, 
the processor transfers the absolute address of 
the pertinent result descriptor to IX1 and clears 
the result descriptor area to zero after transfer- 
ring the two most significant bits of the result 
descriptor to the comparison flip-flops. If the 
comparison is high (operation complete and no 
exceptions), the processor executes a Move Al- 
phanumeric instruction with a field length of 
100 for both the A and B fields. The address 
controllers for the A and B fields are 8-bit for- 
mat and unsigned 4-bit format, respectively. 
The A and B addresses are both 001000. This 
move strips off the zone bits (most significant 
digit of a character) and compresses the field 
to 100 4-bit digits. A branch is taken to location 
001000. 


If the comparison is equal, indicating that the 
peripheral control returned an exception bit, 
operation contained in the above paragraph is 
automatically retried. 


An invalid descriptor causes the processor to 
halt and the comparison LOW indicator is set. 


CONSOLE 


The operator console shown in figure 2-13 con- 
sists of two panels: a display panel and a con- 
trol panel. The display panel is the vertical 
upper panel; the control panel is the curved 
lower panel that is placed on a slope with the 
display panel. 


Display Panel 


The display panel contains a NIXIE ® tube dis- 
play and back-lighted fixed message displays. 
The display panel can be divided into three 
areas as follows: 


a. A NIXIE ® tube display consisting of two 
groups of tubes representing six contiguous 
digits of memory data or address informa- 
tion. Each group is appropriately identified 
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Figure 2-13. Operator’s Console 


by one of three legends which are illuminated 
directly below the tube display when the sys- 
tem is operating in that particular mode. 
Each tube position is capable of displaying all 
16 digits of the extended binary set. Undigits 
will be displayed as their decimal value, less 
ten, with a slash through the digit. A halt, 
either programmed or manual, displays the 
legend OP AF BF and INSTRUCTION AD- 
DRESS. An 8-digit instruction (Address 
Branch, Exit, Halt Branch) displays its OP 
Code on the left side of the display panel and 
the instruction address on the right side. 
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When indirect field length is specified in the 
AF or BF fields, the display in the AF or BF 
positions is the resultant field length and not 
the bit combination specifying indirect field 
and its address. When a literal is specified in 
the AF field, the bit combination specifying 
the literal operand and the bit combination 
specifying the controller are cleared to zero 
before display. Subsequent use of the A key 
on the control panel displays the address of 
the operand and not the literal. The left 
group of six NIXIE ® tubes on the display 
panel reflects: 
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(1) OP AF BF (first interruption syllable). 


(2) MEMORY ADDRESS. 
(3) PROGRAM ADDRESS. 


The right group of six NIXIE ® tubes reflects: 
(4) INSTRUCTION ADDRESS. 
(5) MEMORY INFORMATION. 
(6) BASE and LIMIT (registers). 
b. Twenty back-lighted channel indicators 
(00-19) that illuminate when an appropriate 
channel is busy, and are used for testing pur- 


poses. Indicators 20-23 are used by the Main- 
tenance Test Routine (MTR). 


c. Back-lighted, fixed-message indicators 
which reflect the state of the logical flip- 
flops. Control state operation is indicated by 
the NORMAL indicator not being lit. The 
PROGRAM indicator lights when an invalid 
operation or an invalid address is encoun- 
tered. The PROGRAM and CHECK indica- 
tors light when an instruction time out oc- 
eurs. The CHECK indicator lights if a parity 
interrupt occurs. The INTERRUPT indicator 
lights if a logical interrupt is not completed. 
A complete list of the indicators is as follows: 


(1) NORMAL. 

(2) LOW. 

(3) PROGRAM. 
(4) ASCII. 

(5) EQUAL. 

(6) CHECK. 

(7) TEST. 

(8) INTERRUPT. 
(9) HIGH. 

(10) OVERFLOW. 


Control Panel 


The control panel consists of keys which allow 
the operator to enter information into registers 
or memory, keys to control the display of infor- 
mation, a key to start and stop the processor, 
one key for emergency power off, one key for 
terminating operation, and keys for power on 
and off. The uses of these keys are as follows: 


CL (CLEAR) KEY 


When this key is pressed, all of the flip-flops 
in the processor, I/O controls, central control, 
and memory control are reset to the cleared 
state and the limit register is set to the system 
memory size. This key is only active when all 
I/O operations are completed and the processor 
is halted. 


LD (LOAD) KEY 


After the system has been cleared by the CL 
key, pressing this key initiates the normal load 
operation. Loading of the Operating System is 
performed on the I/O channel that has been 
predesignated (normally the systems memory 
or a disk unit) by the field engineer. 


STOP/RUN KEY 


The STOP/RUN key serves two functions. If 
the processor is running, pressing the key 
causes the processor to stop. If the processor is 
stopped, pressing the key causes the processor 
to continue execution of the stopped program. 
A stop will only occur at the end of the instruc- 
tion being executed; the keyboard is inactive 
until all of the I/O operations are completed. 
The status of processor operations is indicated 
by the stop or run indicators located near the 
STOP/RUN key. 


SI (SINGLE INSTRUCTION) KEY 


This is a single step key which is active when 
the processor is in a stopped status. Pressing 
this key causes the current instruction dis- 
played in the NIXIE ® tube display to be 
executed and the next to be fetched and dis- 
played in the NIXIE ® tube display. If the cur- 
rent instruction is a Halt instruction, only a 
fetch and display of the next instruction occurs. 
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OI (OPERATOR INTERRUPT) KEY 


The system may be interrupted temporarily by 
the operator pressing this switch. 


OP KEY 


This key is active in the stopped status only. 
Pressing this key causes the OP AF BF and ad- 
dress of the current instruction to be displayed 
in the left and right groups of NIXIE ® tubes, 
respectively. Digits can then be entered, right 
to left, into the OP AF BF register from the 
keyboard. The entry of the first digit blanks the 
left-most NIXIE ® tubes and the first digit will 
be displayed. The remaining digits will be dis- 
played as they are entered from the keyboard. 


A, B AND C (FIELD ADDRESS) KEYS 


These three keys all essentially perform the 
same function as the OP key and are only ac- 
tive when the processor is in a stopped status. 
Pressing any one of the three keys causes the 
OP AF BF of the current instruction to be dis- 
played in the left group of NIXIE ® tubes. The 
right group of NIXIE ® tubes will contain the 
A, B, or C field address of the instruction, de- 
pending on whether the A, B and C key was 
pressed. 


PA (PROGRAM ADDRESS) KEY 


This key is only active in the stopped status. 
Pressing the key causes the program address of 
the next instruction to be displayed in the left 
group of NIXIE ® tubes. The three-digit base 
register and three-digit limit register values 
will be displayed in the right group of NIXIE® 
tubes. The program address can be changed by 
entering digits from the keyboard. Entry of the 
first digit blanks the display and the first digit 
of the new program address will be displayed. A 
limit of six digits can be entered, at which time 
the keyboard becomes inactive. 


AD (ADDRESS) KEY 


This key is only active in the stopped status. 
When the key is pressed, the memory address 
register is displayed in the left group of NIXIE® 
tubes and the information contained at that ad- 
dress is displayed in the right group of NIXIE® 
tubes. A limit of six digits can be entered from 
the keyboard to change the memory address. 


Entry of the first address digit blanks the re- 
maining display and will move from right to 
left. The entered digits are shifted with newly 
entered digits following, until the register is 
full. 


WR (WRITE) KEY 


This key can only be used after pressing the AD 
key and is used to write new information into 
core memory, a digit at a time, via the key- 
board. The memory address register advances 
one digit position for each entry. The digit cur- 
rently contained at the memory address ap- 
pears left-justified in the right group of NIXIE® 
tubes, and the keyboard entry digit is right- 
justified. It is not necessary to change a digit, 
it can be bypassed by means of the SKIP key. 
Once the WR key is pressed, the write function 
is active until one of the other keys is pressed 
(other than a digit or SKIP key). 


SKIP KEY 


This key is only active after the WR key has 
placed the keyboard into a write function sta- 
tus. Pressing this key causes the memory ad- 
dress register to increase by one digit position. 
It is used to skip over digit positions that are 
not to be changed in core memory. 


READ KEY 


This key is active only after the AD key has 
been pressed. When displaying information 
from core memory, this key causes the next dig- 
it (or groups of digits) to be read from memory 
and displayed in the right group of NIXIE ® 
tubes. The memory address is increased by one 
if the address is not modulo-4. Once the address 
is modulo-4, words will be read out and the ad- 
dress will increment by four. 


BM (BASE MEMORY) KEY 


When this key is pressed and used in conjunc- 
tion with other appropriate keys, the memory 
address, program address, or instruction ad- 
dress is displayed base relative instead of its 
absolute systems address. 


CS (CONTROL STATE) KEY 


This key is used in conjunction with the SI (sin- 
gle instruction) key. In normal state, the SI key 
causes execution of a single instruction. If the 
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execution of that single instruction causes a re- 
turn to control state when this key is active, all 
control state instructions are executed 
continuously and the processor halts only when 
normal state is reinstated. Thus, the execution 
of a Branch Communicate instruction consists 
of the execution of all control state instructions 
associated with the Branch Communicate. 


TERM (TERMINATE) KEY 


This key performs the same function as the CL 
(clear) key except that this key is always active 
and provides an absolute means of halting the 
processor which otherwise may not be able to 
be halted because of undefined hardware or 
program difficulties. The halt is immediate and 
all displays are blank. 


DIGIT KEYS 


A total of sixteen digit keys on the keyboard 
are available for manually entering information 
into the system. The ten keys, labeled 0 through 
9, represent the 4-bit binary values of decimal 
digits 0 through 9, whereas the other six keys, 
labeled 0 through 5, represent the 4-bit binary 
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values of 10 through 15 for entering the upper 
4-bit stack of 8-bit character combinations. The 
transfer of this information is controlled by the 
previous pressing of an appropriate control key. 
The keyboard is active in the stop state and in- 
active in the run state. 


EMERG PULL OFF (EMERGENCY 
POWER) KEY 


This switch provides a signal to an external de- 
vice that causes power to be removed from all 
of the units. This signal is not distributed to the 
system and no system unit has the capability to 
respond to this signal. It is provided for emer- 
gency conditions only and must not be used for 
normal power shutdown operations. 


PWR ON KEY 
This key is used to apply power to the system. 
PWR OFF KEY 


This key is used to remove power from the sys- 
tem. 


SECTION 3 


SYSTEM POWER CONFIGURATION 


GENERAL 


In general, the power supplies are modular and 
each cabinet contains a major portion of the 
power required to service that cabinet. Figure 
3-1 shows a three cabinet system and the basic 
interfacing between cabinets. The processor 
supplies a +160 volt DC source voltage to the 
other two cabinets. The sequence controls and 
three control voltages, -10 volts, +10 volts, and 
+19 volts are located in the processor. A special 
DC supply, which may be located in any cabinet 
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Figure 3-1. General Power Interface Block Diagram 


3-1 


except the processor, supplies special DC volt- 
ages to the other two cabinets. Each cabinet 
contains voltage sensing circuits which are re- 
turned to the sequence control in the processor 
to cycle power off if an over or undervoltage 
occurs, or if a supply voltage did not come up 
in the allotted time during a power on cycle. 


The following units comprise the system power 
supplies: 


a. Sequence Control. 
b. AC Control. 

c. +170 Volt Supply. 
d. AC to DC Converter. 
e. Inverter. 

f. Special DC Supply. 
g. Memory Supply. 

h. Memory Regulator. 


Figure 3-2 shows the cabinet location of the 
supplies and controls in a typical minimum sys- 
tem configuration as well as the voltage and 
current capabilities of each supply. 


OVERVOLTAGE AND UNDERVOLTAGE 
SENSING 


The overvoltage and undervoltage (OV/UV) 
sensing circuits are used on all supplies except 
the +34 volt supply. The +34 volt supply is 
sensed by the +47 volt regulator. Voltage fail- 
ures are indicated in the following manner: 


a. A lamp within the power supply which has 
failed is turned on. 


b. One of the two lamps on the Processor 
Maintenance Panel is turned on to indicate 
whether the failure encountered was due to 
an OV or UV condition. 


System power is cycled down and, before it can 
be turned on again, the lamps which are 
illuminated must be reset by pressing the PWR 
OFF pushbutton. 
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Figure 3-2. Power Distribution Layout 
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